# **Light Gun - FPGA VGA**

PCS 3335 - Lab Digital A Proposta 12 Jogo "Light Gun" em FPGA

Fernando da Silva Alvarista 13695636 Pedro Henrique 12488289 Endereço GIT:

### Princípio de funcionamento e HARDWARE

- -> Ao se clicar no gatilho, o jogo faz com que apenas os alvos sejam iluminados, de forma com que se a mira estiver correta, o circuito sensor de luz deve enviar um sinal lógico high para a FPGA, indicando assim um tiro certeiro.
- -> Ao se detectar um tiro certeiro a Unidade de Controle, deve eliminar a aparição do objeto que recebeu o tiro.

### Princípio de funcionamento e HARDWARE

Duck Hunt NES on a CRT TV - YouTube

### circuito de detecção de luz



### Construção física da light gun





Figure 3-13 Connections between the FPGA and VGA



Table 3-8 VGA Horizontal Timing Specification

| VGA mode      |                 | Horizontal Timing Spec     |                            |                            |                            |                  |
|---------------|-----------------|----------------------------|----------------------------|----------------------------|----------------------------|------------------|
| Configuration | Resolution(HxV) | a(pixel<br>clock<br>cycle) | b(pixel<br>clock<br>cycle) | c(pixel<br>clock<br>cycle) | d(pixel<br>clock<br>cycle) | Pixel clock(MHz) |
| VGA(60Hz)     | 640x480         | 96                         | 48                         | 640                        | 16                         | 25               |

#### **Table 3-9 VGA Vertical Timing Specification**

| VGA mode      |                 | Vertical Timing Spec |          |          |          |                  |  |
|---------------|-----------------|----------------------|----------|----------|----------|------------------|--|
| Configuration | Resolution(HxV) | a(lines)             | b(lines) | c(lines) | d(lines) | Pixel clock(MHz) |  |
| VGA(60Hz)     | 640x480         | 2                    | 33       | 480      | 10       | 25               |  |





| VGA Timings using 25 MHz Clock |                   |                |  |  |  |  |
|--------------------------------|-------------------|----------------|--|--|--|--|
| Line/Frame Part                | Horizontal Pixels | Vertical Lines |  |  |  |  |
| Whole Area                     | 800               | 525            |  |  |  |  |
| Visible Area                   | 640               | 480            |  |  |  |  |
| Front Porch                    | 18                | 10             |  |  |  |  |
| Sync Pulse                     | 92                | 2              |  |  |  |  |
| Back Porch                     | 50                | 33             |  |  |  |  |

vga\_sync.v



#### vga\_sync.v



## graph\_circuit.v



### graph\_circuit.v



### bang\_bang\_fsm.v / RTL



### graficos\_top.v / RTL



#### **Link GITHUB**

https://github.com/PCS-Poli-USP/projeto-final-projeto-12